查看原文
其他

跟着Nature学绘图——散点图+拟合曲线+分面!

王志山 科研后花园 2023-09-08
 

点击上方

“科研后花园”

关注我们

代码如下:

1、设置工作目录并加载R包:

rm(list=ls())#clear Global Environmentsetwd('D:/散点图+拟合曲线+分面')#设置工作路径
#加载R包library(ggplot2) # Create Elegant Data Visualisations Using the Grammar of Graphicslibrary(ggpmisc) # Miscellaneous Extensions to 'ggplot2'library(ggpubr) # 'ggplot2' Based Publication Ready Plotslibrary(RColorBrewer) # ColorBrewer Paletteslibrary(grid) # The Grid Graphics Packagelibrary(scales) # Scale Functions for Visualization

2、加载绘图数据

df <- read.table(file="data.txt",sep="\t",header=T,check.names=FALSE)

3、自定义颜色:

#自定义颜色col<-c("#1e90ff", "#cb78a6","#e6cf00","#fe0076","#28e5a1")#构建背景色color1 <- colorRampPalette(brewer.pal(11,"PiYG"))(30)

4、绘制散点图并添加拟合曲线:

p1 <- ggplot()+ geom_point(df,mapping=aes(x,y,color=group),size=2,alpha=0.7)+ geom_smooth(df,mapping=aes(x,y),method = "lm", formula = y ~ x,se=F, linetype=1,alpha=0.5)+ stat_cor(df,mapping=aes(x,y),method = "pearson",label.x = 0, label.y = 15,color="black",size=4)+ stat_poly_eq(df,mapping=aes(x,y,label = ..eq.label..), formula = y ~ x, parse = T,color="black", geom = "text",label.x = 0,label.y = 10, hjust = 0,size=4)+ scale_color_manual(values = col)+ theme_classic()+ theme(axis.text=element_text(color='black',size=12), legend.text = element_text(color='black',size=12), legend.title = element_blank(), legend.position = c(0.95,0.85), legend.background = element_blank())+ labs(x=NULL,y=NULL)p1

5、分面:

p2 <- ggplot()+ geom_point(df,mapping=aes(x,y,color=group),size=2,alpha=0.5)+ geom_smooth(df,mapping=aes(x,y,color=group),method = "lm", formula = y ~ x,se=F, linetype=1)+ stat_cor(df,mapping=aes(x,y),color="black",method = "pearson",label.x = 0, label.y = 15,size=4)+ stat_poly_eq(df,mapping=aes(x,y,label = ..eq.label..),color="black", formula = y ~ x, parse = T, geom = "text",label.x = 0,label.y = 10, hjust = 0,size=4)+ scale_color_manual(values = col)+ theme_classic()+ theme(axis.text=element_text(color='black',size=12), legend.text = element_text(color='black',size=12), legend.title = element_blank())+ labs(x=NULL,y=NULL)+ facet_grid(~group, scales = "fixed")+ theme(legend.position = "none", strip.background=element_blank(), strip.text = element_blank()) p2

6、合并图形:

#拼图cowplot::plot_grid(p2,p1,ncol = 1)#添加背景grid.raster(alpha(color1, 0.1), width = unit(1, "npc"), height = unit(1,"npc"), interpolate = T)

温馨提示

如果你喜欢本文,请分享到朋友圈,想要获得更多信息,请关注我。






您可能也对以下帖子感兴趣

R语言画图 | 散点图添加密度分布
R问题|数值模拟流程记录和分享
R语言绘图 | 使用ggplot2绘制发散型柱状图
R语言绘图 | 简单画个圆堆图
R 语言|公式上下标、斜粗体、文本颜色、小数位数等|几乎包含全部所需(更新)

文章有问题?点此查看未经处理的缓存